<template>
  <el-card>
    <el-space>
      <el-space>
        <el-button v-auth="'gps:device_renew_recorder:save'" icon="Plus" type="primary" @click="addOrUpdateHandle()">新增</el-button>
      </el-space>
    </el-space>
    <el-table v-loading="state.dataListLoading" :data="state.dataList" border class="layout-table" @selection-change="selectionChangeHandle">
      <el-table-column  type="index" label="" header-align="center" align="center"></el-table-column>
      <el-table-column prop="logo" label="LOGO" header-align="center" align="center">
        <template #default="scope">
          <el-avatar :size="50" :src="scope.row.logo" />
        </template>
      </el-table-column>
      <el-table-column prop="title" label="标题" header-align="center" align="center"></el-table-column>
      <el-table-column prop="targetLink" label="Html链接" header-align="center" align="center">
        <template #default="scope">
          <span>
            {{ url + '/gps/articleMsg/html?id=' + scope.row.id }}
          </span>
        </template>
      </el-table-column>
      <el-table-column prop="readNum" label="阅读总数" header-align="center" align="center"></el-table-column>
      <el-table-column prop="createTime" label="添加时间" header-align="center" align="center"></el-table-column>
      <el-table-column prop="updateTime" label="修改时间" header-align="center" align="center"></el-table-column>
      <el-table-column label="操作" fixed="right" header-align="center" align="center" width="150">
        <template #default="scope">
          <el-button v-auth="'gps:device_renew_recorder:update'" type="primary" link @click="addOrUpdateHandle(scope.row.id)">修改</el-button>
          <el-button v-auth="'gps:device_renew_recorder:delete'" type="primary" link @click="deleteBatchHandle(scope.row.id)">删除</el-button>
        </template>
      </el-table-column>
    </el-table>
    <el-pagination
      :current-page="state.page"
      :page-sizes="state.pageSizes"
      :page-size="state.limit"
      :total="state.total"
      layout="total, sizes, prev, pager, next, jumper"
      @size-change="sizeChangeHandle"
      @current-change="currentChangeHandle">
    </el-pagination>

    <!-- 弹窗, 新增 / 修改 -->
    <add-or-update ref="addOrUpdateRef" @refresh-data-list="getDataList"></add-or-update>
  </el-card>
</template>

<script setup lang="ts" name="GpsDevice_renew_recorderIndex">
import { useCrud } from '@/hooks'
import { reactive, ref } from 'vue'
import { IHooksOptions } from '@/hooks/interface'
import AddOrUpdate from './add-or-update.vue'

const state: IHooksOptions = reactive({
  dataListUrl: '/gps/articleMsg/list',
  deleteUrl: '/gps/articleMsg/delete',
  queryForm: {
    imei: ''
  }
})
const url = import.meta.env.VITE_API_URL
const queryRef = ref()
const addOrUpdateRef = ref()
const addOrUpdateHandle = (id?: number) => {
  addOrUpdateRef.value.init(id)
}

const { getDataList, selectionChangeHandle, sizeChangeHandle, currentChangeHandle, deleteBatchHandle, reset } = useCrud(state)
</script>
